package org.jypj.dev.service;

import org.jypj.dev.model.TrainStation;
import org.jypj.dev.util.Page;

import java.util.List;
import java.util.Map;

public interface ITrainStationService {


    /**
     * 保存
     * 所有字段全都保存
     *
     * @param trainStation
     * @return
     */
    public int saveTrainStation(TrainStation trainStation);

    /**
     * 根据ID删除
     *
     * @param id 主键ID
     * @return 删除记录数
     */
    public int deleteTrainStationById(String id);

    /**
     * 根据对象删除
     *
     * @param trainStation
     * @return
     */
    public int deleteTrainStationByObject(TrainStation trainStation);

    /**
     * 更新
     * 更新所有字段
     *
     * @param trainStation
     * @return
     */
    public int updateTrainStation(TrainStation trainStation);

    /**
     * 按ID查询
     *
     * @return TrainStation
     * @parm id 主键ID
     */
    public TrainStation selectTrainStationById(String id);

    /**
     * 分页查询 包含条件
     *
     * @param page 分页对象
     * @param map  查询条件
     * @return List<TrainStation>
     */
    public Page selectOnePageByMap(Page page, Map<String, Object> map);

    /**
     * 分页查询 包含对象条件
     *
     * @param page 分页对象
     * @param map  查询条件
     * @return Page
     */
    public Page selectOnePageByTrainStation(Page page, TrainStation trainStation);

    /**
     * 按条件查询全部的
     *
     * @param map 查询条件
     * @return List<TrainStation>
     */
    public List<TrainStation> selectAllByMap(Map<String, Object> map);

    /**
     * 按条件查询全部的
     *
     * @param map 查询条件
     * @return List<TrainStation>
     */
    public List<TrainStation> selectAllStation(Map<String, Object> map);

    /**
     * 按条件查询全部的
     *
     * @param trainStation 查询条件
     * @return List<TrainStation>
     */
    public List<TrainStation> selectAllByTrainStation(TrainStation trainStation);

    /**
     * 按条件查询单个对象
     *
     * @param map 查询条件
     * @return TrainStation
     */
    public TrainStation selectObjectByMap(Map<String, Object> map);

    /**
     * 按条件查询单个对象
     *
     * @param trainStation 查询条件
     * @return TrainStation
     */
    public TrainStation selectObjectByTrainStation(TrainStation trainStation);

    /**
     * 按车次ID查询
     *
     * @param trainId
     * @return
     */
    public List<TrainStation> selectTrainStationsByTrainId(String trainId);

}
